The ODE45 Function

To numerically solve ODE's in Matlab, use the Matlab ode45 function. The ode45 command is a variable step solver (which means that it automatically chooses the value of h for each time step) and is based on an explicit Runge-Kutta (4,5) formula, the Dormand-Prince pair. This is a combination 4th and 5th order method and thus it is very accurate. The ode45 function needs only the solution at the immediately preceding time point to compute the next value of y(tk). Thus it has the same character as the simple Euler's method that we studied earlier. It is beyond the scope of this course to discuss these higher order methods, but if you are interested, a reference for this method is Dormand, J. R. and P. J. Prince, "A family of embedded Runge-Kutta formulae", J. Comp. Appl. Math., Vol. 6, 1980, pp 19-26.

Solving an ODE using Matlab's ode45

Recall that numeric solutions to ODE's create sets of points and require an ODE in general form and an initial condition. For Matlab to solve ODE's, these steps must occur.

  1. The ODE must be written in standard form. This means that the derivative is on the left hand side of the equal sign and the calculation of the derivative is on the right hand side of the equation.
  2. A function must be defined that evaluates the right hand side of the ODE and follows a specific form as required by ode45. This form is described next.
  3. An initial condition (ie. y(0)=10) must be known.
  4. The ode45 function must be called with an appropriate time span and initial condition.
  5. The results of ode45 are then plotted to show the solution.

The rhsode function. This function can have any valid function name, but it must be defined as follows for it to work properly when called by ode45.

The Matlab code for numerically solving an ODE with initial condtion y(0)=10, is:

1     clear;
2     tspan = [ 0, 8 ]; % set time interval from t=0 to t=8
3     y0 = 10;          % set initial condition, y(0)=10 in this case
4     % rhsode is a user-defined function that evaluates the r.h.s. of the ode
5     [t,y] = ode45( 'rhsode' , tspan , y0 );
6     plot(t,y)         % plot the solution returned by ode45
7     [t,y]             % print out t and y(t) 

Type or copy the above code into a Matlab m-file named solveode.m. The line numbers are only for reference and are not part of the script. Here is a line by line description of the code:

Line 1 clears out all previously defined variables. This is important to do, because Matlab remembers the values of variables from previously executed scripts and these can foul-up a calculation.

Line 2 sets the initial time and the ending time at which the solution is computed. These two numbers are assigned to the row vector called tspan. This variable name could be anything, but tspan is somewhat descriptive of its contents. Notice that this line does not use a colon (:) to generate a list of numbers -- tspan is a vector containing only two elements, the start time and the end time.

Line 3 assigns the initial value of the unknown solution function, as y0=10. We give the initial value the name y0. From tspan we know that the initial value of t is 0. Thus lines 2 and 3 together specify the complete initial condition y(0)=10 and the ending time of the solution function, t=8.

Line 4 is a comment that describes the next statement.

Line 5 is the call to the Matlab ode45 command. The syntax of line 5 is very important to understand.

The left hand side of the line 5 assignment statement names two vectors that will be assigned the values that the ode45 function returns.

The right hand side of the line 5 assignment statement calls the ode45 function.

Thus the pair of vectors [t,y] comprise the numerical solution of the ODE defined by the rhsode function since they define points on a graph that can be plotted. The vectors may be hundreds of elements long and will always have the same number of elements. Remember that vector indexing starts with 1 rather than 0, and that the initial time t0 and initial value y0 are stored in vector elements t(1) and y(1), respectively. This can be especially confusing when your initial time t0 is zero.

Line 6 plots the solution t vs. y. Recall that these are both vectors so that the plot command plots all of these points on a graph. Because ode45 chooses h to be very small, there are enough solution points so that the plotted curve looks continuous. However, it is really just a sequence of discrete points.

Line 7 outputs the contents of t and y. This line is not necessary and is usually not done. We show it here so that students can see that the step size between successive points in time t is not uniform. The particular size of the time step is a property of the specific Runge-Kutta algorithm chosen.

This diagram shows how Matlab works to numerically solve an ODE system. The main script sets up the call to ode45. The Command Interpreter interprets the call and executes the the ode45 function's code. The code in the ode45 function uses the current t and y(t) values to pick the next time value and y(t) estimate. It then calculates the derivative, stores it, and uses it to calculate the next values. This continues until the end time is reached and the results are returned to the caller.

ode45 calls your rhsode function to evaluate the ODE at selected time values